home *** CD-ROM | disk | FTP | other *** search
Wrap
Text File | 1998-10-27 | 8.7 KB | 279 lines | [ TEXT/ScoM]
ample type pattern This function takes as its name the AMPLE computer music composition language developed by Chris Jordan in the early 1980s for the BBC computer. The basic language protocol for AMPLE provided an efficient representation of pitch, note-length and duration within a single stream of code. Thus it comes close to representating traditional stave notation. The SCOM function ample provides a close equivalent of this representation which may provide a valuable scoring tool in certain situations, most particularly when working in chromatic tonalities where the pitch range within a part is extensive. The function makes use of the following parameters: note paramete: symbol (a b c d ..) or pitch (c4 c#4 d4 ...) rest parameter: = length parameter: ratio (1/8) ; only positive ratios length expand : / chords : symbols abc, pitches c4_c#4_d4 repeat: [ ] In the example below using symbols notice that one first creates a list containing the note-length instruction prefacing a sequence of symbols. This means all the symbols following the note-length element will be played in that note-length. In addition to symbols and rest-symbols there is a 'new' SCOM symbol meaning a length expansion, thus: (1/8 a / / b) will mean a sounding for 3/8 followed by b sounding for an 1/8. The composer then extracts lengths from symbols via the ample function, usually in the def-symbol / def-length section of the score-file. (setq pat1 '(1/8 a / / b c d / = 1/12 a -b c d / = 1/4 g / h / b m)) (ample :length pat1) => (3/8 1/8 1/8 1/4 -1/8 1/12 1/12 1/12 1/6 -1/12 1/2 1/2 1/4 1/4) (ample :symbol pat1) => (a b c d a -b c d g h b m) In this further example notice how note-lists (with a corresponding tonality (chromatic c 5) may be used in place of symbols. The first list of shown below incorporates another symbol new to SCOM, the repeat sign [ . .]. (setq pat2 '(([ 1/8 a4 / / a4 d#4 a4 / / ]) (1/12 = a4 d#5 f#5 a5 / 1/4 a&4))) (ample :length pat2) => ((3/8 1/8 1/8 3/8 3/8 1/8 1/8 3/8) (-1/12 1/12 1/12 1/12 1/6 1/4)) (ample :symbol pat2) => ((j j d j j j d j) (j p s v i)) The following example shows how chords may be notated; in both symbol and pitch forms. (setq pat3 '(1/8 a b / / hnb 1/4 f / / 1/2 j k 1/8 a =)) (ample :symbol pat3) => (a b hnb f j k a) (ample :length pat3) => (1/8 3/8 1/8 3/4 1/2 1/2 1/8 -1/8) (setq pat4 '(1/8 c4 c#4 / / g4_c#5_d&4 1/4 f4 / / 1/2 a4 b&4 1/8 c4 =)) (ample :symbol pat4) => (a b hnb f j k a) (ample :length pat4) => (1/8 3/8 1/8 3/4 1/2 1/2 1/8 -1/8) ;;; ----------------------------------------------------------------------------- ;;; J.S.Bach Wohltemperierters Klavier, Erste Teil, Praeludium I. ;;; ----------------------------------------------------------------------------- (setq rh '(([ 1/8 = 1/16 g4 c5 e5 g4 c5 e5 ]) ([ 1/8 = 1/16 a4 d5 f5 a4 d5 f5 ]) ([ 1/8 = 1/16 g4 d5 f5 g4 d5 f5 ]) ([ 1/8 = 1/16 g4 c5 e5 g4 c5 e5 ]) ([ 1/8 = 1/16 a4 e5 a5 a4 e5 a5 ]) ; 5 ([ 1/8 = 1/16 f#4 a4 d5 f#4 a4 d5 ]) ([ 1/8 = 1/16 g4 d5 g5 g4 d5 g5 ]) ([ 1/8 = 1/16 e4 g4 c5 e4 g4 c5 ]) ([ 1/8 = 1/16 e4 g4 c5 e4 g4 c5 ]) ([ 1/8 = 1/16 d4 f#4 c5 d4 f#4 c5 ]) ; 10 ([ 1/8 = 1/16 d4 g4 b4 d4 g4 b4 ]) ([ 1/8 = 1/16 e4 g4 c#5 e4 g4 c#5 ]) ([ 1/8 = 1/16 d4 a4 d5 d4 a4 d5 ]) ([ 1/8 = 1/16 d4 f4 b4 d4 f4 b4 ]) ([ 1/8 = 1/16 c4 g4 c5 c4 g4 c5 ]) ; 15 ([ 1/8 = 1/16 a3 c4 f4 a3 c4 f4 ]) ([ 1/8 = 1/16 a3 c4 f4 a3 c4 f4 ]) ([ 1/8 = 1/16 g3 b3 f4 g3 b3 f4 ]) ([ 1/8 = 1/16 g3 c4 e4 g3 c4 e4 ]) ([ 1/8 = 1/16 b&3 c4 e4 b&3 c4 e4 ]) ; 20 ([ 1/8 = 1/16 a3 c4 e4 a3 c4 e4 ]) ([ 1/8 = 1/16 a3 c4 e&4 a3 c4 e&4 ]) ([ 1/8 = 1/16 b3 c4 d4 b3 c4 d4 ]) ([ 1/8 = 1/16 g3 b3 d4 g3 b3 d4 ]) ([ 1/8 = 1/16 g3 c4 e4 g3 c4 e4 ]) ; 25 ([ 1/8 = 1/16 g3 c4 f4 g3 c4 f4 ]) ([ 1/8 = 1/16 g3 b3 f4 g3 b3 f4 ]) ([ 1/8 = 1/16 a3 c4 f#4 a3 c4 f#4 ]) ([ 1/8 = 1/16 g3 c4 g4 g3 c4 g4 ]) ([ 1/8 = 1/16 g3 c4 f4 g3 c4 f4 ]) ; 30 ([ 1/8 = 1/16 g3 b3 f4 g3 b3 f4 ]) ([ 1/8 = 1/16 g3 b&3 e4 g3 b&3 e4 ]) (1/8 = 1/16 f3 a3 c4 f4 c4 a3 c4 a3 f3 a3 f3 d3 f3 d3) (1/8 = 1/16 g4 b4 d5 f5 d5 b4 d5 b4 g4 b4 d4 f4 e4 d4) (1/1 e4_g4_c5)) ; 35 lh1 '(([ 1/16 = 7/16 e4 ]) ([ 1/16 = 7/16 d4 ]) ([ 1/16 = 7/16 d4 ]) ([ 1/16 = 7/16 e4 ]) ([ 1/16 = 7/16 e4 ]) ; 5 ([ 1/16 = 7/16 d4 ]) ([ 1/16 = 7/16 d4 ]) ([ 1/16 = 7/16 c4 ]) ([ 1/16 = 7/16 c4 ]) ([ 1/16 = 7/16 a3 ]) ; 10 ([ 1/16 = 7/16 b3 ]) ([ 1/16 = 7/16 b&3 ]) ([ 1/16 = 7/16 a3 ]) ([ 1/16 = 7/16 a&3 ]) ([ 1/16 = 7/16 g3 ]) ; 15 ([ 1/16 = 7/16 f3 ]) ([ 1/16 = 7/16 f3 ]) ([ 1/16 = 7/16 d3 ]) ([ 1/16 = 7/16 e3 ]) ([ 1/16 = 7/16 g3 ]) ; 20 ([ 1/16 = 7/16 f3 ]) ([ 1/16 = 7/16 c3 ]) ([ 1/16 = 7/16 f3 ]) ([ 1/16 = 7/16 f3 ]) ([ 1/16 = 7/16 e3 ]) ; 25 ([ 1/16 = 7/16 d3 ]) ([ 1/16 = 7/16 d3 ]) ([ 1/16 = 7/16 e&3 ]) ([ 1/16 = 7/16 e3 ]) ([ 1/16 = 7/16 d3 ]) ; 30 ([ 1/16 = 7/16 d3 ]) ([ 1/16 = 7/16 c3 ]) (1/16 = 15/16 c3) (1/16 = 15/16 b2) (1/1 c3)) ; 35 lh2 '((1/2 c4 c4) (1/2 c4 c4) (1/2 b3 b3) (1/2 c4 c4) (1/2 c4 c4) ; 5 (1/2 c4 c4) (1/2 b3 b3) (1/2 b3 b3) (1/2 a3 a3) (1/2 d3 d3) ; 10 (1/2 g3 g3) (1/2 g3 g3) (1/2 f3 f3) (1/2 f3 f3) (1/2 e3 e3) ; 15 (1/2 e3 e3) (1/2 d3 d3) (1/2 g2 g2) (1/2 c3 c3) (1/2 c3 c3) ; 20 (1/2 f2 f2) (1/2 f#2 f#2) (1/2 a&2 a&2) (1/2 g2 g2) (1/2 g2 g2) ; 25 (1/2 g2 g2) (1/2 g2 g2) (1/2 g2 g2) (1/2 g2 g2) (1/2 g2 g2) ; 30 (1/2 g2 g2) (1/2 c2 c2) (1/1 c2) (1/1 c2) (1/1 c2))) ; 35 (setq velocity-lh (append (mapcar #'(lambda (x y) (symbol-transpose x y)) (gen-cresc-dim 0 6 11) (gen-repeat 11 (list (gen-repeat 4 '(48 47 52))))) (mapcar #'(lambda (x y) (symbol-transpose x y)) (gen-dim 0 -8 4) (gen-repeat 4 (list (gen-repeat 4 '(48 47 52))))) (mapcar #'(lambda (x y) (symbol-transpose x y)) (gen-dim 0 -12 9) (gen-repeat 9 (list (gen-repeat 4 '(46 46 49))))) (mapcar #'(lambda (x y) (symbol-transpose x y)) (gen-cresc 0 23 5) (gen-repeat 5 (list (gen-repeat 4 '(42 42 44))))) (mapcar #'(lambda (x y) (symbol-transpose x y)) (gen-dim 25 0 3) (gen-repeat 3 (list (gen-repeat 4 '(43 43 44))))) (gen-repeat 2 (list (gen-repeat 4 '(44 44 44)))) '((48))) velocity-rh1 (mapcar 'list (append (gen-cresc-dim 54 60 15) (gen-dim 54 44 9) (gen-cresc 54 74 5) (gen-dim 71 44 5) '(48))) velocity-rh2 (mapcar 'list (append (gen-cresc-dim 52 58 15) (gen-dim 52 45 9) (gen-cresc 54 74 5) (gen-dim 69 44 5) '(48)))) (setq tempo-value (flatten (list (gen-repeat 15 '(61)) (gen-repeat 15 '(60)) (gen-repeat 2 '(58)) (gen-repeat 1 '(56)) (gen-repeat 12 '(55)) (gen-dim 45 20 4) '50)) tempo (flatten (list (gen-repeat 33 '(1/1)) (gen-repeat 16 '(1/16)) '1/1))) (def-symbol rhand (ample :symbol rh) lhand1 (ample :symbol lh1) lhand2 (ample :symbol lh2)) (def-length rhand (ample :length rh) lhand1 (ample :length lh1) lhand2 (ample :length lh2)) (def-velocity rhand velocity-lh lhand1 velocity-rh1 lhand2 velocity-rh2) (def-duration rhand (append (p-replace-section nil '(3 6 10 13) '1/128 (gen-repeat 4 (g-integer 1 15)) (subseq (length-of rhand) 0 15)) (p-replace-section nil '(3 6 10 13) '1/64 (gen-repeat 4 (g-integer 1 14)) (subseq (length-of rhand) 15 29)) (subseq (length-of rhand) 29 35)) lhand1 (length-of lhand1) lhand2 (length-of lhand2)) (def-zone tempo tempo default (zone-tick (length-of rhand))) (def-channel default k2000i-1) (def-program k2000p default stereo-grand) (def-tonality default (activate-tonality (chromatic c 5))) (def-tempo tempo-value) (compile-instrument "ccl;output:" "JSB_WK_I_P1" rhand lhand1 lhand2) ;;; ----------------------------------------------------------------------------- ;;; jp96 ;;; -----------------------------------------------------------------------------